17B - Hierarchy - CodeForces Solution


dfs and similar dsu greedy shortest paths *1500

Please click on ads to support us..

C++ Code:

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

struct DSU{ //Disjoint Set Union (o Union Find)
    vector <int> parent, sz;
    DSU(int n){
        parent.resize(n);
        sz.resize(n);
        for(int i=0; i<n; i++){
            parent[i] = i;
            sz[i] = 1;
        }
    }
    int find_set(int v){
        if(v == parent[v]) return v;
        return parent[v] = find_set(parent[v]);
    }
    void union_set(int a, int b){
        a = find_set(a);
        b = find_set(b);
        if(a != b){
            if(sz[a] < sz[b])
                swap(a,b);
            parent[b] = a;
            sz[a] += sz[b];
        }
    }
};

ll kruskal(int n, vector<tuple<ll,int,int>> &edges){
	DSU dsu(n);
	sort(edges.begin(), edges.end());

	ll ans = 0;
	vector<bool> rel(n,false);
	for(auto [w, u, v] : edges){ // (C++17 only)
		if(!rel[v] && dsu.find_set(u) != dsu.find_set(v)){
			ans += w;
			dsu.union_set(u, v);
			rel[v] = true;
		}
	}
	int cnt = 0;
	for(int i=0; i<n; i++) 
		if(!rel[i]) 
			cnt++;
	if(cnt > 1) 
		return -1;

	return ans;
}


int main(){
	ios_base::sync_with_stdio(0); cin.tie(0);
	int n, m;	cin >> n;
	for(int i=0; i<n; i++) cin >> m;
	cin >> m;
	vector <tuple<ll,int,int>> edges(m);
	for(int i=0; i<m; i++){
		int u, v;
		ll w;
		cin >> u >> v >> w;
		u--;
		v--;
		edges[i] = {w, u, v};
	}
	cout << kruskal(n, edges) << '\n';
	return 0;
}

									 	  		 					   	 					


Comments

Submit
0 Comments
More Questions

938A - Word Correction
159C - String Manipulation 10
258A - Little Elephant and Bits
1536C - Diluc and Kaeya
1428C - ABBB
1557A - Ezzat and Two Subsequences
255A - Greg's Workout
1059A - Cashier
1389C - Good String
1561A - Simply Strange Sort
1337B - Kana and Dragon Quest game
137C - History
1443C - The Delivery Dilemma
6C - Alice Bob and Chocolate
1077C - Good Array
285B - Find Marble
6A - Triangle
1729A - Two Elevators
1729B - Decode String
1729C - Jumping on Tiles
1729E - Guess the Cycle Size
553B - Kyoya and Permutation
1729D - Friends and the Restaurant
1606C - Banknotes
580C - Kefa and Park
342A - Xenia and Divisors
1033A - King Escape
39D - Cubical Planet
1453A - Cancel the Trains
645A - Amity Assessment